↳ ITRS
↳ ITRStoQTRSProof
z
Cond_f(TRUE, x, y, z) → f(x, y, +@z(z, 1@z))
f(x, y, z) → Cond_f(>@z(x, +@z(y, z)), x, y, z)
Cond_f1(TRUE, x, y, z) → f(x, +@z(y, 1@z), z)
f(x, y, z) → Cond_f1(>@z(x, +@z(y, z)), x, y, z)
Cond_f(TRUE, x0, x1, x2)
f(x0, x1, x2)
Cond_f1(TRUE, x0, x1, x2)
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
Cond_f(true, x, y, z) → f(x, y, plus_int(pos(s(0)), z))
f(x, y, z) → Cond_f(greater_int(x, plus_int(y, z)), x, y, z)
Cond_f1(true, x, y, z) → f(x, plus_int(pos(s(0)), y), z)
f(x, y, z) → Cond_f1(greater_int(x, plus_int(y, z)), x, y, z)
plus_int(pos(x), neg(y)) → minus_nat(x, y)
plus_int(neg(x), pos(y)) → minus_nat(y, x)
plus_int(neg(x), neg(y)) → neg(plus_nat(x, y))
plus_int(pos(x), pos(y)) → pos(plus_nat(x, y))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
greater_int(pos(0), pos(0)) → false
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
Cond_f(true, x0, x1, x2)
f(x0, x1, x2)
Cond_f1(true, x0, x1, x2)
plus_int(pos(x0), neg(x1))
plus_int(neg(x0), pos(x1))
plus_int(neg(x0), neg(x1))
plus_int(pos(x0), pos(x1))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
COND_F(true, x, y, z) → F(x, y, plus_int(pos(s(0)), z))
COND_F(true, x, y, z) → PLUS_INT(pos(s(0)), z)
F(x, y, z) → COND_F(greater_int(x, plus_int(y, z)), x, y, z)
F(x, y, z) → GREATER_INT(x, plus_int(y, z))
F(x, y, z) → PLUS_INT(y, z)
COND_F1(true, x, y, z) → F(x, plus_int(pos(s(0)), y), z)
COND_F1(true, x, y, z) → PLUS_INT(pos(s(0)), y)
F(x, y, z) → COND_F1(greater_int(x, plus_int(y, z)), x, y, z)
PLUS_INT(pos(x), neg(y)) → MINUS_NAT(x, y)
PLUS_INT(neg(x), pos(y)) → MINUS_NAT(y, x)
PLUS_INT(neg(x), neg(y)) → PLUS_NAT(x, y)
PLUS_INT(pos(x), pos(y)) → PLUS_NAT(x, y)
PLUS_NAT(s(x), y) → PLUS_NAT(x, y)
MINUS_NAT(s(x), s(y)) → MINUS_NAT(x, y)
GREATER_INT(pos(s(x)), pos(s(y))) → GREATER_INT(pos(x), pos(y))
GREATER_INT(neg(s(x)), neg(s(y))) → GREATER_INT(neg(x), neg(y))
Cond_f(true, x, y, z) → f(x, y, plus_int(pos(s(0)), z))
f(x, y, z) → Cond_f(greater_int(x, plus_int(y, z)), x, y, z)
Cond_f1(true, x, y, z) → f(x, plus_int(pos(s(0)), y), z)
f(x, y, z) → Cond_f1(greater_int(x, plus_int(y, z)), x, y, z)
plus_int(pos(x), neg(y)) → minus_nat(x, y)
plus_int(neg(x), pos(y)) → minus_nat(y, x)
plus_int(neg(x), neg(y)) → neg(plus_nat(x, y))
plus_int(pos(x), pos(y)) → pos(plus_nat(x, y))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
greater_int(pos(0), pos(0)) → false
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
Cond_f(true, x0, x1, x2)
f(x0, x1, x2)
Cond_f1(true, x0, x1, x2)
plus_int(pos(x0), neg(x1))
plus_int(neg(x0), pos(x1))
plus_int(neg(x0), neg(x1))
plus_int(pos(x0), pos(x1))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
COND_F(true, x, y, z) → F(x, y, plus_int(pos(s(0)), z))
COND_F(true, x, y, z) → PLUS_INT(pos(s(0)), z)
F(x, y, z) → COND_F(greater_int(x, plus_int(y, z)), x, y, z)
F(x, y, z) → GREATER_INT(x, plus_int(y, z))
F(x, y, z) → PLUS_INT(y, z)
COND_F1(true, x, y, z) → F(x, plus_int(pos(s(0)), y), z)
COND_F1(true, x, y, z) → PLUS_INT(pos(s(0)), y)
F(x, y, z) → COND_F1(greater_int(x, plus_int(y, z)), x, y, z)
PLUS_INT(pos(x), neg(y)) → MINUS_NAT(x, y)
PLUS_INT(neg(x), pos(y)) → MINUS_NAT(y, x)
PLUS_INT(neg(x), neg(y)) → PLUS_NAT(x, y)
PLUS_INT(pos(x), pos(y)) → PLUS_NAT(x, y)
PLUS_NAT(s(x), y) → PLUS_NAT(x, y)
MINUS_NAT(s(x), s(y)) → MINUS_NAT(x, y)
GREATER_INT(pos(s(x)), pos(s(y))) → GREATER_INT(pos(x), pos(y))
GREATER_INT(neg(s(x)), neg(s(y))) → GREATER_INT(neg(x), neg(y))
Cond_f(true, x, y, z) → f(x, y, plus_int(pos(s(0)), z))
f(x, y, z) → Cond_f(greater_int(x, plus_int(y, z)), x, y, z)
Cond_f1(true, x, y, z) → f(x, plus_int(pos(s(0)), y), z)
f(x, y, z) → Cond_f1(greater_int(x, plus_int(y, z)), x, y, z)
plus_int(pos(x), neg(y)) → minus_nat(x, y)
plus_int(neg(x), pos(y)) → minus_nat(y, x)
plus_int(neg(x), neg(y)) → neg(plus_nat(x, y))
plus_int(pos(x), pos(y)) → pos(plus_nat(x, y))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
greater_int(pos(0), pos(0)) → false
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
Cond_f(true, x0, x1, x2)
f(x0, x1, x2)
Cond_f1(true, x0, x1, x2)
plus_int(pos(x0), neg(x1))
plus_int(neg(x0), pos(x1))
plus_int(neg(x0), neg(x1))
plus_int(pos(x0), pos(x1))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QDP
↳ QDP
↳ QDP
GREATER_INT(neg(s(x)), neg(s(y))) → GREATER_INT(neg(x), neg(y))
Cond_f(true, x, y, z) → f(x, y, plus_int(pos(s(0)), z))
f(x, y, z) → Cond_f(greater_int(x, plus_int(y, z)), x, y, z)
Cond_f1(true, x, y, z) → f(x, plus_int(pos(s(0)), y), z)
f(x, y, z) → Cond_f1(greater_int(x, plus_int(y, z)), x, y, z)
plus_int(pos(x), neg(y)) → minus_nat(x, y)
plus_int(neg(x), pos(y)) → minus_nat(y, x)
plus_int(neg(x), neg(y)) → neg(plus_nat(x, y))
plus_int(pos(x), pos(y)) → pos(plus_nat(x, y))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
greater_int(pos(0), pos(0)) → false
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
Cond_f(true, x0, x1, x2)
f(x0, x1, x2)
Cond_f1(true, x0, x1, x2)
plus_int(pos(x0), neg(x1))
plus_int(neg(x0), pos(x1))
plus_int(neg(x0), neg(x1))
plus_int(pos(x0), pos(x1))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ QDP
↳ QDP
↳ QDP
GREATER_INT(neg(s(x)), neg(s(y))) → GREATER_INT(neg(x), neg(y))
Cond_f(true, x0, x1, x2)
f(x0, x1, x2)
Cond_f1(true, x0, x1, x2)
plus_int(pos(x0), neg(x1))
plus_int(neg(x0), pos(x1))
plus_int(neg(x0), neg(x1))
plus_int(pos(x0), pos(x1))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
Cond_f(true, x0, x1, x2)
f(x0, x1, x2)
Cond_f1(true, x0, x1, x2)
plus_int(pos(x0), neg(x1))
plus_int(neg(x0), pos(x1))
plus_int(neg(x0), neg(x1))
plus_int(pos(x0), pos(x1))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ UsableRulesReductionPairsProof
↳ QDP
↳ QDP
↳ QDP
↳ QDP
GREATER_INT(neg(s(x)), neg(s(y))) → GREATER_INT(neg(x), neg(y))
No rules are removed from R.
GREATER_INT(neg(s(x)), neg(s(y))) → GREATER_INT(neg(x), neg(y))
POL(GREATER_INT(x1, x2)) = 2·x1 + x2
POL(neg(x1)) = x1
POL(s(x1)) = 2·x1
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ UsableRulesReductionPairsProof
↳ QDP
↳ PisEmptyProof
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QDP
↳ QDP
GREATER_INT(pos(s(x)), pos(s(y))) → GREATER_INT(pos(x), pos(y))
Cond_f(true, x, y, z) → f(x, y, plus_int(pos(s(0)), z))
f(x, y, z) → Cond_f(greater_int(x, plus_int(y, z)), x, y, z)
Cond_f1(true, x, y, z) → f(x, plus_int(pos(s(0)), y), z)
f(x, y, z) → Cond_f1(greater_int(x, plus_int(y, z)), x, y, z)
plus_int(pos(x), neg(y)) → minus_nat(x, y)
plus_int(neg(x), pos(y)) → minus_nat(y, x)
plus_int(neg(x), neg(y)) → neg(plus_nat(x, y))
plus_int(pos(x), pos(y)) → pos(plus_nat(x, y))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
greater_int(pos(0), pos(0)) → false
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
Cond_f(true, x0, x1, x2)
f(x0, x1, x2)
Cond_f1(true, x0, x1, x2)
plus_int(pos(x0), neg(x1))
plus_int(neg(x0), pos(x1))
plus_int(neg(x0), neg(x1))
plus_int(pos(x0), pos(x1))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ QDP
↳ QDP
GREATER_INT(pos(s(x)), pos(s(y))) → GREATER_INT(pos(x), pos(y))
Cond_f(true, x0, x1, x2)
f(x0, x1, x2)
Cond_f1(true, x0, x1, x2)
plus_int(pos(x0), neg(x1))
plus_int(neg(x0), pos(x1))
plus_int(neg(x0), neg(x1))
plus_int(pos(x0), pos(x1))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
Cond_f(true, x0, x1, x2)
f(x0, x1, x2)
Cond_f1(true, x0, x1, x2)
plus_int(pos(x0), neg(x1))
plus_int(neg(x0), pos(x1))
plus_int(neg(x0), neg(x1))
plus_int(pos(x0), pos(x1))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ UsableRulesReductionPairsProof
↳ QDP
↳ QDP
↳ QDP
GREATER_INT(pos(s(x)), pos(s(y))) → GREATER_INT(pos(x), pos(y))
No rules are removed from R.
GREATER_INT(pos(s(x)), pos(s(y))) → GREATER_INT(pos(x), pos(y))
POL(GREATER_INT(x1, x2)) = 2·x1 + x2
POL(pos(x1)) = x1
POL(s(x1)) = 2·x1
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ UsableRulesReductionPairsProof
↳ QDP
↳ PisEmptyProof
↳ QDP
↳ QDP
↳ QDP
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QDP
MINUS_NAT(s(x), s(y)) → MINUS_NAT(x, y)
Cond_f(true, x, y, z) → f(x, y, plus_int(pos(s(0)), z))
f(x, y, z) → Cond_f(greater_int(x, plus_int(y, z)), x, y, z)
Cond_f1(true, x, y, z) → f(x, plus_int(pos(s(0)), y), z)
f(x, y, z) → Cond_f1(greater_int(x, plus_int(y, z)), x, y, z)
plus_int(pos(x), neg(y)) → minus_nat(x, y)
plus_int(neg(x), pos(y)) → minus_nat(y, x)
plus_int(neg(x), neg(y)) → neg(plus_nat(x, y))
plus_int(pos(x), pos(y)) → pos(plus_nat(x, y))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
greater_int(pos(0), pos(0)) → false
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
Cond_f(true, x0, x1, x2)
f(x0, x1, x2)
Cond_f1(true, x0, x1, x2)
plus_int(pos(x0), neg(x1))
plus_int(neg(x0), pos(x1))
plus_int(neg(x0), neg(x1))
plus_int(pos(x0), pos(x1))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ QDP
MINUS_NAT(s(x), s(y)) → MINUS_NAT(x, y)
Cond_f(true, x0, x1, x2)
f(x0, x1, x2)
Cond_f1(true, x0, x1, x2)
plus_int(pos(x0), neg(x1))
plus_int(neg(x0), pos(x1))
plus_int(neg(x0), neg(x1))
plus_int(pos(x0), pos(x1))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
Cond_f(true, x0, x1, x2)
f(x0, x1, x2)
Cond_f1(true, x0, x1, x2)
plus_int(pos(x0), neg(x1))
plus_int(neg(x0), pos(x1))
plus_int(neg(x0), neg(x1))
plus_int(pos(x0), pos(x1))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ QDPSizeChangeProof
↳ QDP
↳ QDP
MINUS_NAT(s(x), s(y)) → MINUS_NAT(x, y)
From the DPs we obtained the following set of size-change graphs:
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
PLUS_NAT(s(x), y) → PLUS_NAT(x, y)
Cond_f(true, x, y, z) → f(x, y, plus_int(pos(s(0)), z))
f(x, y, z) → Cond_f(greater_int(x, plus_int(y, z)), x, y, z)
Cond_f1(true, x, y, z) → f(x, plus_int(pos(s(0)), y), z)
f(x, y, z) → Cond_f1(greater_int(x, plus_int(y, z)), x, y, z)
plus_int(pos(x), neg(y)) → minus_nat(x, y)
plus_int(neg(x), pos(y)) → minus_nat(y, x)
plus_int(neg(x), neg(y)) → neg(plus_nat(x, y))
plus_int(pos(x), pos(y)) → pos(plus_nat(x, y))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
greater_int(pos(0), pos(0)) → false
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
Cond_f(true, x0, x1, x2)
f(x0, x1, x2)
Cond_f1(true, x0, x1, x2)
plus_int(pos(x0), neg(x1))
plus_int(neg(x0), pos(x1))
plus_int(neg(x0), neg(x1))
plus_int(pos(x0), pos(x1))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
PLUS_NAT(s(x), y) → PLUS_NAT(x, y)
Cond_f(true, x0, x1, x2)
f(x0, x1, x2)
Cond_f1(true, x0, x1, x2)
plus_int(pos(x0), neg(x1))
plus_int(neg(x0), pos(x1))
plus_int(neg(x0), neg(x1))
plus_int(pos(x0), pos(x1))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
Cond_f(true, x0, x1, x2)
f(x0, x1, x2)
Cond_f1(true, x0, x1, x2)
plus_int(pos(x0), neg(x1))
plus_int(neg(x0), pos(x1))
plus_int(neg(x0), neg(x1))
plus_int(pos(x0), pos(x1))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ QDPSizeChangeProof
↳ QDP
PLUS_NAT(s(x), y) → PLUS_NAT(x, y)
From the DPs we obtained the following set of size-change graphs:
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
F(x, y, z) → COND_F(greater_int(x, plus_int(y, z)), x, y, z)
COND_F(true, x, y, z) → F(x, y, plus_int(pos(s(0)), z))
F(x, y, z) → COND_F1(greater_int(x, plus_int(y, z)), x, y, z)
COND_F1(true, x, y, z) → F(x, plus_int(pos(s(0)), y), z)
Cond_f(true, x, y, z) → f(x, y, plus_int(pos(s(0)), z))
f(x, y, z) → Cond_f(greater_int(x, plus_int(y, z)), x, y, z)
Cond_f1(true, x, y, z) → f(x, plus_int(pos(s(0)), y), z)
f(x, y, z) → Cond_f1(greater_int(x, plus_int(y, z)), x, y, z)
plus_int(pos(x), neg(y)) → minus_nat(x, y)
plus_int(neg(x), pos(y)) → minus_nat(y, x)
plus_int(neg(x), neg(y)) → neg(plus_nat(x, y))
plus_int(pos(x), pos(y)) → pos(plus_nat(x, y))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
greater_int(pos(0), pos(0)) → false
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
Cond_f(true, x0, x1, x2)
f(x0, x1, x2)
Cond_f1(true, x0, x1, x2)
plus_int(pos(x0), neg(x1))
plus_int(neg(x0), pos(x1))
plus_int(neg(x0), neg(x1))
plus_int(pos(x0), pos(x1))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
F(x, y, z) → COND_F(greater_int(x, plus_int(y, z)), x, y, z)
COND_F(true, x, y, z) → F(x, y, plus_int(pos(s(0)), z))
F(x, y, z) → COND_F1(greater_int(x, plus_int(y, z)), x, y, z)
COND_F1(true, x, y, z) → F(x, plus_int(pos(s(0)), y), z)
plus_int(pos(x), neg(y)) → minus_nat(x, y)
plus_int(neg(x), pos(y)) → minus_nat(y, x)
plus_int(neg(x), neg(y)) → neg(plus_nat(x, y))
plus_int(pos(x), pos(y)) → pos(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
Cond_f(true, x0, x1, x2)
f(x0, x1, x2)
Cond_f1(true, x0, x1, x2)
plus_int(pos(x0), neg(x1))
plus_int(neg(x0), pos(x1))
plus_int(neg(x0), neg(x1))
plus_int(pos(x0), pos(x1))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
Cond_f(true, x0, x1, x2)
f(x0, x1, x2)
Cond_f1(true, x0, x1, x2)
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
F(x, y, z) → COND_F(greater_int(x, plus_int(y, z)), x, y, z)
COND_F(true, x, y, z) → F(x, y, plus_int(pos(s(0)), z))
F(x, y, z) → COND_F1(greater_int(x, plus_int(y, z)), x, y, z)
COND_F1(true, x, y, z) → F(x, plus_int(pos(s(0)), y), z)
plus_int(pos(x), neg(y)) → minus_nat(x, y)
plus_int(neg(x), pos(y)) → minus_nat(y, x)
plus_int(neg(x), neg(y)) → neg(plus_nat(x, y))
plus_int(pos(x), pos(y)) → pos(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
plus_int(pos(x0), neg(x1))
plus_int(neg(x0), pos(x1))
plus_int(neg(x0), neg(x1))
plus_int(pos(x0), pos(x1))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ QDP
↳ RemovalProof
↳ Narrowing
F(x, y, z, x_removed) → COND_F(greater_int(x, plus_int(y, z)), x, y, z, x_removed)
COND_F(true, x, y, z, x_removed) → F(x, y, plus_int(x_removed, z), x_removed)
F(x, y, z, x_removed) → COND_F1(greater_int(x, plus_int(y, z)), x, y, z, x_removed)
COND_F1(true, x, y, z, x_removed) → F(x, plus_int(x_removed, y), z, x_removed)
plus_int(pos(x), neg(y)) → minus_nat(x, y)
plus_int(neg(x), pos(y)) → minus_nat(y, x)
plus_int(neg(x), neg(y)) → neg(plus_nat(x, y))
plus_int(pos(x), pos(y)) → pos(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
plus_int(pos(x0), neg(x1))
plus_int(neg(x0), pos(x1))
plus_int(neg(x0), neg(x1))
plus_int(pos(x0), pos(x1))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ QDP
↳ Narrowing
F(x, y, z, x_removed) → COND_F(greater_int(x, plus_int(y, z)), x, y, z, x_removed)
COND_F(true, x, y, z, x_removed) → F(x, y, plus_int(x_removed, z), x_removed)
F(x, y, z, x_removed) → COND_F1(greater_int(x, plus_int(y, z)), x, y, z, x_removed)
COND_F1(true, x, y, z, x_removed) → F(x, plus_int(x_removed, y), z, x_removed)
plus_int(pos(x), neg(y)) → minus_nat(x, y)
plus_int(neg(x), pos(y)) → minus_nat(y, x)
plus_int(neg(x), neg(y)) → neg(plus_nat(x, y))
plus_int(pos(x), pos(y)) → pos(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
plus_int(pos(x0), neg(x1))
plus_int(neg(x0), pos(x1))
plus_int(neg(x0), neg(x1))
plus_int(pos(x0), pos(x1))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
F(y0, neg(x0), neg(x1)) → COND_F(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
F(y0, neg(x0), pos(x1)) → COND_F(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, pos(x0), neg(x1)) → COND_F(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
F(y0, pos(x0), pos(x1)) → COND_F(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
COND_F(true, x, y, z) → F(x, y, plus_int(pos(s(0)), z))
F(x, y, z) → COND_F1(greater_int(x, plus_int(y, z)), x, y, z)
COND_F1(true, x, y, z) → F(x, plus_int(pos(s(0)), y), z)
F(y0, neg(x0), neg(x1)) → COND_F(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
F(y0, neg(x0), pos(x1)) → COND_F(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, pos(x0), neg(x1)) → COND_F(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
F(y0, pos(x0), pos(x1)) → COND_F(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
plus_int(pos(x), neg(y)) → minus_nat(x, y)
plus_int(neg(x), pos(y)) → minus_nat(y, x)
plus_int(neg(x), neg(y)) → neg(plus_nat(x, y))
plus_int(pos(x), pos(y)) → pos(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
plus_int(pos(x0), neg(x1))
plus_int(neg(x0), pos(x1))
plus_int(neg(x0), neg(x1))
plus_int(pos(x0), pos(x1))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
F(y0, neg(x0), neg(x1)) → COND_F1(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
F(y0, neg(x0), pos(x1)) → COND_F1(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, pos(x0), neg(x1)) → COND_F1(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
F(y0, pos(x0), pos(x1)) → COND_F1(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
COND_F(true, x, y, z) → F(x, y, plus_int(pos(s(0)), z))
COND_F1(true, x, y, z) → F(x, plus_int(pos(s(0)), y), z)
F(y0, neg(x0), neg(x1)) → COND_F(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
F(y0, neg(x0), pos(x1)) → COND_F(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, pos(x0), neg(x1)) → COND_F(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
F(y0, pos(x0), pos(x1)) → COND_F(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
F(y0, neg(x0), neg(x1)) → COND_F1(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
F(y0, neg(x0), pos(x1)) → COND_F1(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, pos(x0), neg(x1)) → COND_F1(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
F(y0, pos(x0), pos(x1)) → COND_F1(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
plus_int(pos(x), neg(y)) → minus_nat(x, y)
plus_int(neg(x), pos(y)) → minus_nat(y, x)
plus_int(neg(x), neg(y)) → neg(plus_nat(x, y))
plus_int(pos(x), pos(y)) → pos(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
plus_int(pos(x0), neg(x1))
plus_int(neg(x0), pos(x1))
plus_int(neg(x0), neg(x1))
plus_int(pos(x0), pos(x1))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
COND_F(true, x, y, z) → F(x, y, plus_int(pos(s(0)), z))
COND_F1(true, x, y, z) → F(x, plus_int(pos(s(0)), y), z)
F(y0, neg(x0), neg(x1)) → COND_F(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
F(y0, neg(x0), pos(x1)) → COND_F(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, pos(x0), neg(x1)) → COND_F(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
F(y0, pos(x0), pos(x1)) → COND_F(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
F(y0, neg(x0), neg(x1)) → COND_F1(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
F(y0, neg(x0), pos(x1)) → COND_F1(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, pos(x0), neg(x1)) → COND_F1(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
F(y0, pos(x0), pos(x1)) → COND_F1(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
plus_int(pos(x), neg(y)) → minus_nat(x, y)
plus_int(pos(x), pos(y)) → pos(plus_nat(x, y))
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
plus_int(pos(x0), neg(x1))
plus_int(neg(x0), pos(x1))
plus_int(neg(x0), neg(x1))
plus_int(pos(x0), pos(x1))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
COND_F(true, y0, y1, pos(x1)) → F(y0, y1, pos(plus_nat(s(0), x1)))
COND_F(true, y0, y1, neg(x1)) → F(y0, y1, minus_nat(s(0), x1))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
COND_F1(true, x, y, z) → F(x, plus_int(pos(s(0)), y), z)
F(y0, neg(x0), neg(x1)) → COND_F(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
F(y0, neg(x0), pos(x1)) → COND_F(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, pos(x0), neg(x1)) → COND_F(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
F(y0, pos(x0), pos(x1)) → COND_F(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
F(y0, neg(x0), neg(x1)) → COND_F1(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
F(y0, neg(x0), pos(x1)) → COND_F1(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, pos(x0), neg(x1)) → COND_F1(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
F(y0, pos(x0), pos(x1)) → COND_F1(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
COND_F(true, y0, y1, pos(x1)) → F(y0, y1, pos(plus_nat(s(0), x1)))
COND_F(true, y0, y1, neg(x1)) → F(y0, y1, minus_nat(s(0), x1))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
plus_int(pos(x), neg(y)) → minus_nat(x, y)
plus_int(pos(x), pos(y)) → pos(plus_nat(x, y))
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
plus_int(pos(x0), neg(x1))
plus_int(neg(x0), pos(x1))
plus_int(neg(x0), neg(x1))
plus_int(pos(x0), pos(x1))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
COND_F(true, y0, y1, pos(x1)) → F(y0, y1, pos(s(plus_nat(0, x1))))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
COND_F1(true, x, y, z) → F(x, plus_int(pos(s(0)), y), z)
F(y0, neg(x0), neg(x1)) → COND_F(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
F(y0, neg(x0), pos(x1)) → COND_F(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, pos(x0), neg(x1)) → COND_F(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
F(y0, pos(x0), pos(x1)) → COND_F(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
F(y0, neg(x0), neg(x1)) → COND_F1(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
F(y0, neg(x0), pos(x1)) → COND_F1(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, pos(x0), neg(x1)) → COND_F1(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
F(y0, pos(x0), pos(x1)) → COND_F1(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
COND_F(true, y0, y1, neg(x1)) → F(y0, y1, minus_nat(s(0), x1))
COND_F(true, y0, y1, pos(x1)) → F(y0, y1, pos(s(plus_nat(0, x1))))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
plus_int(pos(x), neg(y)) → minus_nat(x, y)
plus_int(pos(x), pos(y)) → pos(plus_nat(x, y))
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
plus_int(pos(x0), neg(x1))
plus_int(neg(x0), pos(x1))
plus_int(neg(x0), neg(x1))
plus_int(pos(x0), pos(x1))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
COND_F(true, y0, y1, pos(x1)) → F(y0, y1, pos(s(x1)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
COND_F1(true, x, y, z) → F(x, plus_int(pos(s(0)), y), z)
F(y0, neg(x0), neg(x1)) → COND_F(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
F(y0, neg(x0), pos(x1)) → COND_F(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, pos(x0), neg(x1)) → COND_F(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
F(y0, pos(x0), pos(x1)) → COND_F(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
F(y0, neg(x0), neg(x1)) → COND_F1(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
F(y0, neg(x0), pos(x1)) → COND_F1(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, pos(x0), neg(x1)) → COND_F1(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
F(y0, pos(x0), pos(x1)) → COND_F1(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
COND_F(true, y0, y1, neg(x1)) → F(y0, y1, minus_nat(s(0), x1))
COND_F(true, y0, y1, pos(x1)) → F(y0, y1, pos(s(x1)))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
plus_int(pos(x), neg(y)) → minus_nat(x, y)
plus_int(pos(x), pos(y)) → pos(plus_nat(x, y))
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
plus_int(pos(x0), neg(x1))
plus_int(neg(x0), pos(x1))
plus_int(neg(x0), neg(x1))
plus_int(pos(x0), pos(x1))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
COND_F1(true, y0, pos(x1), y2) → F(y0, pos(plus_nat(s(0), x1)), y2)
COND_F1(true, y0, neg(x1), y2) → F(y0, minus_nat(s(0), x1), y2)
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
F(y0, neg(x0), neg(x1)) → COND_F(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
F(y0, neg(x0), pos(x1)) → COND_F(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, pos(x0), neg(x1)) → COND_F(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
F(y0, pos(x0), pos(x1)) → COND_F(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
F(y0, neg(x0), neg(x1)) → COND_F1(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
F(y0, neg(x0), pos(x1)) → COND_F1(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, pos(x0), neg(x1)) → COND_F1(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
F(y0, pos(x0), pos(x1)) → COND_F1(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
COND_F(true, y0, y1, neg(x1)) → F(y0, y1, minus_nat(s(0), x1))
COND_F(true, y0, y1, pos(x1)) → F(y0, y1, pos(s(x1)))
COND_F1(true, y0, pos(x1), y2) → F(y0, pos(plus_nat(s(0), x1)), y2)
COND_F1(true, y0, neg(x1), y2) → F(y0, minus_nat(s(0), x1), y2)
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
plus_int(pos(x), neg(y)) → minus_nat(x, y)
plus_int(pos(x), pos(y)) → pos(plus_nat(x, y))
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
plus_int(pos(x0), neg(x1))
plus_int(neg(x0), pos(x1))
plus_int(neg(x0), neg(x1))
plus_int(pos(x0), pos(x1))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
F(y0, neg(x0), neg(x1)) → COND_F(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
F(y0, neg(x0), pos(x1)) → COND_F(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, pos(x0), neg(x1)) → COND_F(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
F(y0, pos(x0), pos(x1)) → COND_F(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
F(y0, neg(x0), neg(x1)) → COND_F1(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
F(y0, neg(x0), pos(x1)) → COND_F1(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, pos(x0), neg(x1)) → COND_F1(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
F(y0, pos(x0), pos(x1)) → COND_F1(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
COND_F(true, y0, y1, neg(x1)) → F(y0, y1, minus_nat(s(0), x1))
COND_F(true, y0, y1, pos(x1)) → F(y0, y1, pos(s(x1)))
COND_F1(true, y0, pos(x1), y2) → F(y0, pos(plus_nat(s(0), x1)), y2)
COND_F1(true, y0, neg(x1), y2) → F(y0, minus_nat(s(0), x1), y2)
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
plus_int(pos(x0), neg(x1))
plus_int(neg(x0), pos(x1))
plus_int(neg(x0), neg(x1))
plus_int(pos(x0), pos(x1))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
plus_int(pos(x0), neg(x1))
plus_int(neg(x0), pos(x1))
plus_int(neg(x0), neg(x1))
plus_int(pos(x0), pos(x1))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
F(y0, neg(x0), neg(x1)) → COND_F(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
F(y0, neg(x0), pos(x1)) → COND_F(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, pos(x0), neg(x1)) → COND_F(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
F(y0, pos(x0), pos(x1)) → COND_F(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
F(y0, neg(x0), neg(x1)) → COND_F1(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
F(y0, neg(x0), pos(x1)) → COND_F1(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, pos(x0), neg(x1)) → COND_F1(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
F(y0, pos(x0), pos(x1)) → COND_F1(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
COND_F(true, y0, y1, neg(x1)) → F(y0, y1, minus_nat(s(0), x1))
COND_F(true, y0, y1, pos(x1)) → F(y0, y1, pos(s(x1)))
COND_F1(true, y0, pos(x1), y2) → F(y0, pos(plus_nat(s(0), x1)), y2)
COND_F1(true, y0, neg(x1), y2) → F(y0, minus_nat(s(0), x1), y2)
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
COND_F1(true, y0, pos(x1), y2) → F(y0, pos(s(plus_nat(0, x1))), y2)
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
F(y0, neg(x0), neg(x1)) → COND_F(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
F(y0, neg(x0), pos(x1)) → COND_F(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, pos(x0), neg(x1)) → COND_F(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
F(y0, pos(x0), pos(x1)) → COND_F(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
F(y0, neg(x0), neg(x1)) → COND_F1(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
F(y0, neg(x0), pos(x1)) → COND_F1(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, pos(x0), neg(x1)) → COND_F1(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
F(y0, pos(x0), pos(x1)) → COND_F1(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
COND_F(true, y0, y1, neg(x1)) → F(y0, y1, minus_nat(s(0), x1))
COND_F(true, y0, y1, pos(x1)) → F(y0, y1, pos(s(x1)))
COND_F1(true, y0, neg(x1), y2) → F(y0, minus_nat(s(0), x1), y2)
COND_F1(true, y0, pos(x1), y2) → F(y0, pos(s(plus_nat(0, x1))), y2)
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
COND_F1(true, y0, pos(x1), y2) → F(y0, pos(s(x1)), y2)
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
F(y0, neg(x0), neg(x1)) → COND_F(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
F(y0, neg(x0), pos(x1)) → COND_F(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, pos(x0), neg(x1)) → COND_F(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
F(y0, pos(x0), pos(x1)) → COND_F(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
F(y0, neg(x0), neg(x1)) → COND_F1(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
F(y0, neg(x0), pos(x1)) → COND_F1(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, pos(x0), neg(x1)) → COND_F1(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
F(y0, pos(x0), pos(x1)) → COND_F1(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
COND_F(true, y0, y1, neg(x1)) → F(y0, y1, minus_nat(s(0), x1))
COND_F(true, y0, y1, pos(x1)) → F(y0, y1, pos(s(x1)))
COND_F1(true, y0, neg(x1), y2) → F(y0, minus_nat(s(0), x1), y2)
COND_F1(true, y0, pos(x1), y2) → F(y0, pos(s(x1)), y2)
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
COND_F(true, z0, neg(z1), neg(z2)) → F(z0, neg(z1), minus_nat(s(0), z2))
COND_F(true, z0, pos(z1), neg(z2)) → F(z0, pos(z1), minus_nat(s(0), z2))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
F(y0, neg(x0), neg(x1)) → COND_F(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
F(y0, neg(x0), pos(x1)) → COND_F(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, pos(x0), neg(x1)) → COND_F(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
F(y0, pos(x0), pos(x1)) → COND_F(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
F(y0, neg(x0), neg(x1)) → COND_F1(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
F(y0, neg(x0), pos(x1)) → COND_F1(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, pos(x0), neg(x1)) → COND_F1(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
F(y0, pos(x0), pos(x1)) → COND_F1(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
COND_F(true, y0, y1, pos(x1)) → F(y0, y1, pos(s(x1)))
COND_F1(true, y0, neg(x1), y2) → F(y0, minus_nat(s(0), x1), y2)
COND_F1(true, y0, pos(x1), y2) → F(y0, pos(s(x1)), y2)
COND_F(true, z0, neg(z1), neg(z2)) → F(z0, neg(z1), minus_nat(s(0), z2))
COND_F(true, z0, pos(z1), neg(z2)) → F(z0, pos(z1), minus_nat(s(0), z2))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
COND_F(true, z0, pos(z1), pos(z2)) → F(z0, pos(z1), pos(s(z2)))
COND_F(true, z0, neg(z1), pos(z2)) → F(z0, neg(z1), pos(s(z2)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
F(y0, neg(x0), neg(x1)) → COND_F(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
F(y0, neg(x0), pos(x1)) → COND_F(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, pos(x0), neg(x1)) → COND_F(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
F(y0, pos(x0), pos(x1)) → COND_F(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
F(y0, neg(x0), neg(x1)) → COND_F1(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
F(y0, neg(x0), pos(x1)) → COND_F1(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, pos(x0), neg(x1)) → COND_F1(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
F(y0, pos(x0), pos(x1)) → COND_F1(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
COND_F1(true, y0, neg(x1), y2) → F(y0, minus_nat(s(0), x1), y2)
COND_F1(true, y0, pos(x1), y2) → F(y0, pos(s(x1)), y2)
COND_F(true, z0, neg(z1), neg(z2)) → F(z0, neg(z1), minus_nat(s(0), z2))
COND_F(true, z0, pos(z1), neg(z2)) → F(z0, pos(z1), minus_nat(s(0), z2))
COND_F(true, z0, pos(z1), pos(z2)) → F(z0, pos(z1), pos(s(z2)))
COND_F(true, z0, neg(z1), pos(z2)) → F(z0, neg(z1), pos(s(z2)))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ Instantiation
↳ QDP
COND_F(true, z0, pos(z1), neg(z2)) → F(z0, pos(z1), minus_nat(s(0), z2))
F(y0, pos(x0), neg(x1)) → COND_F(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
F(y0, pos(x0), pos(x1)) → COND_F(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
COND_F(true, z0, pos(z1), pos(z2)) → F(z0, pos(z1), pos(s(z2)))
F(y0, pos(x0), pos(x1)) → COND_F1(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
COND_F1(true, y0, pos(x1), y2) → F(y0, pos(s(x1)), y2)
F(y0, pos(x0), neg(x1)) → COND_F1(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
COND_F1(true, z0, pos(z1), neg(z2)) → F(z0, pos(s(z1)), neg(z2))
COND_F1(true, z0, pos(z1), pos(z2)) → F(z0, pos(s(z1)), pos(z2))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ QDP
COND_F(true, z0, pos(z1), neg(z2)) → F(z0, pos(z1), minus_nat(s(0), z2))
F(y0, pos(x0), neg(x1)) → COND_F(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
F(y0, pos(x0), pos(x1)) → COND_F(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
COND_F(true, z0, pos(z1), pos(z2)) → F(z0, pos(z1), pos(s(z2)))
F(y0, pos(x0), pos(x1)) → COND_F1(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
F(y0, pos(x0), neg(x1)) → COND_F1(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
COND_F1(true, z0, pos(z1), neg(z2)) → F(z0, pos(s(z1)), neg(z2))
COND_F1(true, z0, pos(z1), pos(z2)) → F(z0, pos(s(z1)), pos(z2))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QDP
COND_F(true, z0, pos(z1), pos(z2)) → F(z0, pos(z1), pos(s(z2)))
F(y0, pos(x0), pos(x1)) → COND_F(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
F(y0, pos(x0), pos(x1)) → COND_F1(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
COND_F1(true, z0, pos(z1), pos(z2)) → F(z0, pos(s(z1)), pos(z2))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ QDP
COND_F(true, z0, pos(z1), pos(z2)) → F(z0, pos(z1), pos(s(z2)))
F(y0, pos(x0), pos(x1)) → COND_F(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
F(y0, pos(x0), pos(x1)) → COND_F1(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
COND_F1(true, z0, pos(z1), pos(z2)) → F(z0, pos(s(z1)), pos(z2))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Instantiation
↳ QDP
↳ QDP
COND_F(true, z0, pos(z1), pos(z2)) → F(z0, pos(z1), pos(s(z2)))
F(y0, pos(x0), pos(x1)) → COND_F(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
F(y0, pos(x0), pos(x1)) → COND_F1(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
COND_F1(true, z0, pos(z1), pos(z2)) → F(z0, pos(s(z1)), pos(z2))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
F(z0, pos(z1), pos(s(z2))) → COND_F(greater_int(z0, pos(plus_nat(z1, s(z2)))), z0, pos(z1), pos(s(z2)))
F(z0, pos(s(z1)), pos(z2)) → COND_F(greater_int(z0, pos(plus_nat(s(z1), z2))), z0, pos(s(z1)), pos(z2))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ QDP
COND_F(true, z0, pos(z1), pos(z2)) → F(z0, pos(z1), pos(s(z2)))
F(y0, pos(x0), pos(x1)) → COND_F1(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
COND_F1(true, z0, pos(z1), pos(z2)) → F(z0, pos(s(z1)), pos(z2))
F(z0, pos(z1), pos(s(z2))) → COND_F(greater_int(z0, pos(plus_nat(z1, s(z2)))), z0, pos(z1), pos(s(z2)))
F(z0, pos(s(z1)), pos(z2)) → COND_F(greater_int(z0, pos(plus_nat(s(z1), z2))), z0, pos(s(z1)), pos(z2))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
F(z0, pos(s(z1)), pos(z2)) → COND_F(greater_int(z0, pos(s(plus_nat(z1, z2)))), z0, pos(s(z1)), pos(z2))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ QDP
COND_F(true, z0, pos(z1), pos(z2)) → F(z0, pos(z1), pos(s(z2)))
F(y0, pos(x0), pos(x1)) → COND_F1(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
COND_F1(true, z0, pos(z1), pos(z2)) → F(z0, pos(s(z1)), pos(z2))
F(z0, pos(z1), pos(s(z2))) → COND_F(greater_int(z0, pos(plus_nat(z1, s(z2)))), z0, pos(z1), pos(s(z2)))
F(z0, pos(s(z1)), pos(z2)) → COND_F(greater_int(z0, pos(s(plus_nat(z1, z2)))), z0, pos(s(z1)), pos(z2))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
COND_F(true, z0, pos(s(z1)), pos(z2)) → F(z0, pos(s(z1)), pos(s(z2)))
COND_F(true, z0, pos(z1), pos(s(z2))) → F(z0, pos(z1), pos(s(s(z2))))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ QDP
F(y0, pos(x0), pos(x1)) → COND_F1(greater_int(y0, pos(plus_nat(x0, x1))), y0, pos(x0), pos(x1))
COND_F1(true, z0, pos(z1), pos(z2)) → F(z0, pos(s(z1)), pos(z2))
F(z0, pos(z1), pos(s(z2))) → COND_F(greater_int(z0, pos(plus_nat(z1, s(z2)))), z0, pos(z1), pos(s(z2)))
F(z0, pos(s(z1)), pos(z2)) → COND_F(greater_int(z0, pos(s(plus_nat(z1, z2)))), z0, pos(s(z1)), pos(z2))
COND_F(true, z0, pos(s(z1)), pos(z2)) → F(z0, pos(s(z1)), pos(s(z2)))
COND_F(true, z0, pos(z1), pos(s(z2))) → F(z0, pos(z1), pos(s(s(z2))))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
F(z0, pos(s(z1)), pos(z2)) → COND_F1(greater_int(z0, pos(plus_nat(s(z1), z2))), z0, pos(s(z1)), pos(z2))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F1(greater_int(z0, pos(plus_nat(s(z1), s(z2)))), z0, pos(s(z1)), pos(s(z2)))
F(z0, pos(z1), pos(s(s(z2)))) → COND_F1(greater_int(z0, pos(plus_nat(z1, s(s(z2))))), z0, pos(z1), pos(s(s(z2))))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ QDP
COND_F1(true, z0, pos(z1), pos(z2)) → F(z0, pos(s(z1)), pos(z2))
F(z0, pos(z1), pos(s(z2))) → COND_F(greater_int(z0, pos(plus_nat(z1, s(z2)))), z0, pos(z1), pos(s(z2)))
F(z0, pos(s(z1)), pos(z2)) → COND_F(greater_int(z0, pos(s(plus_nat(z1, z2)))), z0, pos(s(z1)), pos(z2))
COND_F(true, z0, pos(s(z1)), pos(z2)) → F(z0, pos(s(z1)), pos(s(z2)))
COND_F(true, z0, pos(z1), pos(s(z2))) → F(z0, pos(z1), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(z2)) → COND_F1(greater_int(z0, pos(plus_nat(s(z1), z2))), z0, pos(s(z1)), pos(z2))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F1(greater_int(z0, pos(plus_nat(s(z1), s(z2)))), z0, pos(s(z1)), pos(s(z2)))
F(z0, pos(z1), pos(s(s(z2)))) → COND_F1(greater_int(z0, pos(plus_nat(z1, s(s(z2))))), z0, pos(z1), pos(s(s(z2))))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
F(z0, pos(s(z1)), pos(z2)) → COND_F1(greater_int(z0, pos(s(plus_nat(z1, z2)))), z0, pos(s(z1)), pos(z2))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ QDP
COND_F1(true, z0, pos(z1), pos(z2)) → F(z0, pos(s(z1)), pos(z2))
F(z0, pos(z1), pos(s(z2))) → COND_F(greater_int(z0, pos(plus_nat(z1, s(z2)))), z0, pos(z1), pos(s(z2)))
F(z0, pos(s(z1)), pos(z2)) → COND_F(greater_int(z0, pos(s(plus_nat(z1, z2)))), z0, pos(s(z1)), pos(z2))
COND_F(true, z0, pos(s(z1)), pos(z2)) → F(z0, pos(s(z1)), pos(s(z2)))
COND_F(true, z0, pos(z1), pos(s(z2))) → F(z0, pos(z1), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F1(greater_int(z0, pos(plus_nat(s(z1), s(z2)))), z0, pos(s(z1)), pos(s(z2)))
F(z0, pos(z1), pos(s(s(z2)))) → COND_F1(greater_int(z0, pos(plus_nat(z1, s(s(z2))))), z0, pos(z1), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(z2)) → COND_F1(greater_int(z0, pos(s(plus_nat(z1, z2)))), z0, pos(s(z1)), pos(z2))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F1(greater_int(z0, pos(s(plus_nat(z1, s(z2))))), z0, pos(s(z1)), pos(s(z2)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ QDP
COND_F1(true, z0, pos(z1), pos(z2)) → F(z0, pos(s(z1)), pos(z2))
F(z0, pos(z1), pos(s(z2))) → COND_F(greater_int(z0, pos(plus_nat(z1, s(z2)))), z0, pos(z1), pos(s(z2)))
F(z0, pos(s(z1)), pos(z2)) → COND_F(greater_int(z0, pos(s(plus_nat(z1, z2)))), z0, pos(s(z1)), pos(z2))
COND_F(true, z0, pos(s(z1)), pos(z2)) → F(z0, pos(s(z1)), pos(s(z2)))
COND_F(true, z0, pos(z1), pos(s(z2))) → F(z0, pos(z1), pos(s(s(z2))))
F(z0, pos(z1), pos(s(s(z2)))) → COND_F1(greater_int(z0, pos(plus_nat(z1, s(s(z2))))), z0, pos(z1), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(z2)) → COND_F1(greater_int(z0, pos(s(plus_nat(z1, z2)))), z0, pos(s(z1)), pos(z2))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F1(greater_int(z0, pos(s(plus_nat(z1, s(z2))))), z0, pos(s(z1)), pos(s(z2)))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
COND_F1(true, z0, pos(s(z1)), pos(s(z2))) → F(z0, pos(s(s(z1))), pos(s(z2)))
COND_F1(true, z0, pos(z1), pos(s(s(z2)))) → F(z0, pos(s(z1)), pos(s(s(z2))))
COND_F1(true, z0, pos(s(z1)), pos(z2)) → F(z0, pos(s(s(z1))), pos(z2))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ QDP
F(z0, pos(z1), pos(s(z2))) → COND_F(greater_int(z0, pos(plus_nat(z1, s(z2)))), z0, pos(z1), pos(s(z2)))
F(z0, pos(s(z1)), pos(z2)) → COND_F(greater_int(z0, pos(s(plus_nat(z1, z2)))), z0, pos(s(z1)), pos(z2))
COND_F(true, z0, pos(s(z1)), pos(z2)) → F(z0, pos(s(z1)), pos(s(z2)))
COND_F(true, z0, pos(z1), pos(s(z2))) → F(z0, pos(z1), pos(s(s(z2))))
F(z0, pos(z1), pos(s(s(z2)))) → COND_F1(greater_int(z0, pos(plus_nat(z1, s(s(z2))))), z0, pos(z1), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(z2)) → COND_F1(greater_int(z0, pos(s(plus_nat(z1, z2)))), z0, pos(s(z1)), pos(z2))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F1(greater_int(z0, pos(s(plus_nat(z1, s(z2))))), z0, pos(s(z1)), pos(s(z2)))
COND_F1(true, z0, pos(s(z1)), pos(s(z2))) → F(z0, pos(s(s(z1))), pos(s(z2)))
COND_F1(true, z0, pos(z1), pos(s(s(z2)))) → F(z0, pos(s(z1)), pos(s(s(z2))))
COND_F1(true, z0, pos(s(z1)), pos(z2)) → F(z0, pos(s(s(z1))), pos(z2))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
F(z0, pos(z1), pos(s(s(z2)))) → COND_F(greater_int(z0, pos(plus_nat(z1, s(s(z2))))), z0, pos(z1), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(s(s(z2)))) → COND_F(greater_int(z0, pos(plus_nat(s(z1), s(s(z2))))), z0, pos(s(z1)), pos(s(s(z2))))
F(z0, pos(s(s(z1))), pos(s(z2))) → COND_F(greater_int(z0, pos(plus_nat(s(s(z1)), s(z2)))), z0, pos(s(s(z1))), pos(s(z2)))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F(greater_int(z0, pos(plus_nat(s(z1), s(z2)))), z0, pos(s(z1)), pos(s(z2)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ QDP
F(z0, pos(s(z1)), pos(z2)) → COND_F(greater_int(z0, pos(s(plus_nat(z1, z2)))), z0, pos(s(z1)), pos(z2))
COND_F(true, z0, pos(s(z1)), pos(z2)) → F(z0, pos(s(z1)), pos(s(z2)))
COND_F(true, z0, pos(z1), pos(s(z2))) → F(z0, pos(z1), pos(s(s(z2))))
F(z0, pos(z1), pos(s(s(z2)))) → COND_F1(greater_int(z0, pos(plus_nat(z1, s(s(z2))))), z0, pos(z1), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(z2)) → COND_F1(greater_int(z0, pos(s(plus_nat(z1, z2)))), z0, pos(s(z1)), pos(z2))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F1(greater_int(z0, pos(s(plus_nat(z1, s(z2))))), z0, pos(s(z1)), pos(s(z2)))
COND_F1(true, z0, pos(s(z1)), pos(s(z2))) → F(z0, pos(s(s(z1))), pos(s(z2)))
COND_F1(true, z0, pos(z1), pos(s(s(z2)))) → F(z0, pos(s(z1)), pos(s(s(z2))))
COND_F1(true, z0, pos(s(z1)), pos(z2)) → F(z0, pos(s(s(z1))), pos(z2))
F(z0, pos(z1), pos(s(s(z2)))) → COND_F(greater_int(z0, pos(plus_nat(z1, s(s(z2))))), z0, pos(z1), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(s(s(z2)))) → COND_F(greater_int(z0, pos(plus_nat(s(z1), s(s(z2))))), z0, pos(s(z1)), pos(s(s(z2))))
F(z0, pos(s(s(z1))), pos(s(z2))) → COND_F(greater_int(z0, pos(plus_nat(s(s(z1)), s(z2)))), z0, pos(s(s(z1))), pos(s(z2)))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F(greater_int(z0, pos(plus_nat(s(z1), s(z2)))), z0, pos(s(z1)), pos(s(z2)))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
F(z0, pos(s(z1)), pos(s(s(z2)))) → COND_F(greater_int(z0, pos(s(plus_nat(z1, s(s(z2)))))), z0, pos(s(z1)), pos(s(s(z2))))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ QDP
F(z0, pos(s(z1)), pos(z2)) → COND_F(greater_int(z0, pos(s(plus_nat(z1, z2)))), z0, pos(s(z1)), pos(z2))
COND_F(true, z0, pos(s(z1)), pos(z2)) → F(z0, pos(s(z1)), pos(s(z2)))
COND_F(true, z0, pos(z1), pos(s(z2))) → F(z0, pos(z1), pos(s(s(z2))))
F(z0, pos(z1), pos(s(s(z2)))) → COND_F1(greater_int(z0, pos(plus_nat(z1, s(s(z2))))), z0, pos(z1), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(z2)) → COND_F1(greater_int(z0, pos(s(plus_nat(z1, z2)))), z0, pos(s(z1)), pos(z2))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F1(greater_int(z0, pos(s(plus_nat(z1, s(z2))))), z0, pos(s(z1)), pos(s(z2)))
COND_F1(true, z0, pos(s(z1)), pos(s(z2))) → F(z0, pos(s(s(z1))), pos(s(z2)))
COND_F1(true, z0, pos(z1), pos(s(s(z2)))) → F(z0, pos(s(z1)), pos(s(s(z2))))
COND_F1(true, z0, pos(s(z1)), pos(z2)) → F(z0, pos(s(s(z1))), pos(z2))
F(z0, pos(z1), pos(s(s(z2)))) → COND_F(greater_int(z0, pos(plus_nat(z1, s(s(z2))))), z0, pos(z1), pos(s(s(z2))))
F(z0, pos(s(s(z1))), pos(s(z2))) → COND_F(greater_int(z0, pos(plus_nat(s(s(z1)), s(z2)))), z0, pos(s(s(z1))), pos(s(z2)))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F(greater_int(z0, pos(plus_nat(s(z1), s(z2)))), z0, pos(s(z1)), pos(s(z2)))
F(z0, pos(s(z1)), pos(s(s(z2)))) → COND_F(greater_int(z0, pos(s(plus_nat(z1, s(s(z2)))))), z0, pos(s(z1)), pos(s(s(z2))))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
F(z0, pos(s(s(z1))), pos(s(z2))) → COND_F(greater_int(z0, pos(s(plus_nat(s(z1), s(z2))))), z0, pos(s(s(z1))), pos(s(z2)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ QDP
F(z0, pos(s(z1)), pos(z2)) → COND_F(greater_int(z0, pos(s(plus_nat(z1, z2)))), z0, pos(s(z1)), pos(z2))
COND_F(true, z0, pos(s(z1)), pos(z2)) → F(z0, pos(s(z1)), pos(s(z2)))
COND_F(true, z0, pos(z1), pos(s(z2))) → F(z0, pos(z1), pos(s(s(z2))))
F(z0, pos(z1), pos(s(s(z2)))) → COND_F1(greater_int(z0, pos(plus_nat(z1, s(s(z2))))), z0, pos(z1), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(z2)) → COND_F1(greater_int(z0, pos(s(plus_nat(z1, z2)))), z0, pos(s(z1)), pos(z2))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F1(greater_int(z0, pos(s(plus_nat(z1, s(z2))))), z0, pos(s(z1)), pos(s(z2)))
COND_F1(true, z0, pos(s(z1)), pos(s(z2))) → F(z0, pos(s(s(z1))), pos(s(z2)))
COND_F1(true, z0, pos(z1), pos(s(s(z2)))) → F(z0, pos(s(z1)), pos(s(s(z2))))
COND_F1(true, z0, pos(s(z1)), pos(z2)) → F(z0, pos(s(s(z1))), pos(z2))
F(z0, pos(z1), pos(s(s(z2)))) → COND_F(greater_int(z0, pos(plus_nat(z1, s(s(z2))))), z0, pos(z1), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F(greater_int(z0, pos(plus_nat(s(z1), s(z2)))), z0, pos(s(z1)), pos(s(z2)))
F(z0, pos(s(z1)), pos(s(s(z2)))) → COND_F(greater_int(z0, pos(s(plus_nat(z1, s(s(z2)))))), z0, pos(s(z1)), pos(s(s(z2))))
F(z0, pos(s(s(z1))), pos(s(z2))) → COND_F(greater_int(z0, pos(s(plus_nat(s(z1), s(z2))))), z0, pos(s(s(z1))), pos(s(z2)))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F(greater_int(z0, pos(s(plus_nat(z1, s(z2))))), z0, pos(s(z1)), pos(s(z2)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ QDP
F(z0, pos(s(z1)), pos(z2)) → COND_F(greater_int(z0, pos(s(plus_nat(z1, z2)))), z0, pos(s(z1)), pos(z2))
COND_F(true, z0, pos(s(z1)), pos(z2)) → F(z0, pos(s(z1)), pos(s(z2)))
COND_F(true, z0, pos(z1), pos(s(z2))) → F(z0, pos(z1), pos(s(s(z2))))
F(z0, pos(z1), pos(s(s(z2)))) → COND_F1(greater_int(z0, pos(plus_nat(z1, s(s(z2))))), z0, pos(z1), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(z2)) → COND_F1(greater_int(z0, pos(s(plus_nat(z1, z2)))), z0, pos(s(z1)), pos(z2))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F1(greater_int(z0, pos(s(plus_nat(z1, s(z2))))), z0, pos(s(z1)), pos(s(z2)))
COND_F1(true, z0, pos(s(z1)), pos(s(z2))) → F(z0, pos(s(s(z1))), pos(s(z2)))
COND_F1(true, z0, pos(z1), pos(s(s(z2)))) → F(z0, pos(s(z1)), pos(s(s(z2))))
COND_F1(true, z0, pos(s(z1)), pos(z2)) → F(z0, pos(s(s(z1))), pos(z2))
F(z0, pos(z1), pos(s(s(z2)))) → COND_F(greater_int(z0, pos(plus_nat(z1, s(s(z2))))), z0, pos(z1), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(s(s(z2)))) → COND_F(greater_int(z0, pos(s(plus_nat(z1, s(s(z2)))))), z0, pos(s(z1)), pos(s(s(z2))))
F(z0, pos(s(s(z1))), pos(s(z2))) → COND_F(greater_int(z0, pos(s(plus_nat(s(z1), s(z2))))), z0, pos(s(s(z1))), pos(s(z2)))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F(greater_int(z0, pos(s(plus_nat(z1, s(z2))))), z0, pos(s(z1)), pos(s(z2)))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
F(z0, pos(s(s(z1))), pos(s(z2))) → COND_F(greater_int(z0, pos(s(s(plus_nat(z1, s(z2)))))), z0, pos(s(s(z1))), pos(s(z2)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ QDP
F(z0, pos(s(z1)), pos(z2)) → COND_F(greater_int(z0, pos(s(plus_nat(z1, z2)))), z0, pos(s(z1)), pos(z2))
COND_F(true, z0, pos(s(z1)), pos(z2)) → F(z0, pos(s(z1)), pos(s(z2)))
COND_F(true, z0, pos(z1), pos(s(z2))) → F(z0, pos(z1), pos(s(s(z2))))
F(z0, pos(z1), pos(s(s(z2)))) → COND_F1(greater_int(z0, pos(plus_nat(z1, s(s(z2))))), z0, pos(z1), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(z2)) → COND_F1(greater_int(z0, pos(s(plus_nat(z1, z2)))), z0, pos(s(z1)), pos(z2))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F1(greater_int(z0, pos(s(plus_nat(z1, s(z2))))), z0, pos(s(z1)), pos(s(z2)))
COND_F1(true, z0, pos(s(z1)), pos(s(z2))) → F(z0, pos(s(s(z1))), pos(s(z2)))
COND_F1(true, z0, pos(z1), pos(s(s(z2)))) → F(z0, pos(s(z1)), pos(s(s(z2))))
COND_F1(true, z0, pos(s(z1)), pos(z2)) → F(z0, pos(s(s(z1))), pos(z2))
F(z0, pos(z1), pos(s(s(z2)))) → COND_F(greater_int(z0, pos(plus_nat(z1, s(s(z2))))), z0, pos(z1), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(s(s(z2)))) → COND_F(greater_int(z0, pos(s(plus_nat(z1, s(s(z2)))))), z0, pos(s(z1)), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F(greater_int(z0, pos(s(plus_nat(z1, s(z2))))), z0, pos(s(z1)), pos(s(z2)))
F(z0, pos(s(s(z1))), pos(s(z2))) → COND_F(greater_int(z0, pos(s(s(plus_nat(z1, s(z2)))))), z0, pos(s(s(z1))), pos(s(z2)))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
F(z0, pos(s(s(z1))), pos(z2)) → COND_F(greater_int(z0, pos(s(plus_nat(s(z1), z2)))), z0, pos(s(s(z1))), pos(z2))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F(greater_int(z0, pos(s(plus_nat(z1, s(z2))))), z0, pos(s(z1)), pos(s(z2)))
F(z0, pos(s(x1)), pos(s(s(z2)))) → COND_F(greater_int(z0, pos(s(plus_nat(x1, s(s(z2)))))), z0, pos(s(x1)), pos(s(s(z2))))
F(z0, pos(s(s(z1))), pos(s(z2))) → COND_F(greater_int(z0, pos(s(plus_nat(s(z1), s(z2))))), z0, pos(s(s(z1))), pos(s(z2)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ QDP
COND_F(true, z0, pos(s(z1)), pos(z2)) → F(z0, pos(s(z1)), pos(s(z2)))
COND_F(true, z0, pos(z1), pos(s(z2))) → F(z0, pos(z1), pos(s(s(z2))))
F(z0, pos(z1), pos(s(s(z2)))) → COND_F1(greater_int(z0, pos(plus_nat(z1, s(s(z2))))), z0, pos(z1), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(z2)) → COND_F1(greater_int(z0, pos(s(plus_nat(z1, z2)))), z0, pos(s(z1)), pos(z2))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F1(greater_int(z0, pos(s(plus_nat(z1, s(z2))))), z0, pos(s(z1)), pos(s(z2)))
COND_F1(true, z0, pos(s(z1)), pos(s(z2))) → F(z0, pos(s(s(z1))), pos(s(z2)))
COND_F1(true, z0, pos(z1), pos(s(s(z2)))) → F(z0, pos(s(z1)), pos(s(s(z2))))
COND_F1(true, z0, pos(s(z1)), pos(z2)) → F(z0, pos(s(s(z1))), pos(z2))
F(z0, pos(z1), pos(s(s(z2)))) → COND_F(greater_int(z0, pos(plus_nat(z1, s(s(z2))))), z0, pos(z1), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(s(s(z2)))) → COND_F(greater_int(z0, pos(s(plus_nat(z1, s(s(z2)))))), z0, pos(s(z1)), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F(greater_int(z0, pos(s(plus_nat(z1, s(z2))))), z0, pos(s(z1)), pos(s(z2)))
F(z0, pos(s(s(z1))), pos(s(z2))) → COND_F(greater_int(z0, pos(s(s(plus_nat(z1, s(z2)))))), z0, pos(s(s(z1))), pos(s(z2)))
F(z0, pos(s(s(z1))), pos(z2)) → COND_F(greater_int(z0, pos(s(plus_nat(s(z1), z2)))), z0, pos(s(s(z1))), pos(z2))
F(z0, pos(s(s(z1))), pos(s(z2))) → COND_F(greater_int(z0, pos(s(plus_nat(s(z1), s(z2))))), z0, pos(s(s(z1))), pos(s(z2)))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
F(z0, pos(s(s(z1))), pos(z2)) → COND_F(greater_int(z0, pos(s(s(plus_nat(z1, z2))))), z0, pos(s(s(z1))), pos(z2))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ QDP
COND_F(true, z0, pos(s(z1)), pos(z2)) → F(z0, pos(s(z1)), pos(s(z2)))
COND_F(true, z0, pos(z1), pos(s(z2))) → F(z0, pos(z1), pos(s(s(z2))))
F(z0, pos(z1), pos(s(s(z2)))) → COND_F1(greater_int(z0, pos(plus_nat(z1, s(s(z2))))), z0, pos(z1), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(z2)) → COND_F1(greater_int(z0, pos(s(plus_nat(z1, z2)))), z0, pos(s(z1)), pos(z2))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F1(greater_int(z0, pos(s(plus_nat(z1, s(z2))))), z0, pos(s(z1)), pos(s(z2)))
COND_F1(true, z0, pos(s(z1)), pos(s(z2))) → F(z0, pos(s(s(z1))), pos(s(z2)))
COND_F1(true, z0, pos(z1), pos(s(s(z2)))) → F(z0, pos(s(z1)), pos(s(s(z2))))
COND_F1(true, z0, pos(s(z1)), pos(z2)) → F(z0, pos(s(s(z1))), pos(z2))
F(z0, pos(z1), pos(s(s(z2)))) → COND_F(greater_int(z0, pos(plus_nat(z1, s(s(z2))))), z0, pos(z1), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(s(s(z2)))) → COND_F(greater_int(z0, pos(s(plus_nat(z1, s(s(z2)))))), z0, pos(s(z1)), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F(greater_int(z0, pos(s(plus_nat(z1, s(z2))))), z0, pos(s(z1)), pos(s(z2)))
F(z0, pos(s(s(z1))), pos(s(z2))) → COND_F(greater_int(z0, pos(s(s(plus_nat(z1, s(z2)))))), z0, pos(s(s(z1))), pos(s(z2)))
F(z0, pos(s(s(z1))), pos(s(z2))) → COND_F(greater_int(z0, pos(s(plus_nat(s(z1), s(z2))))), z0, pos(s(s(z1))), pos(s(z2)))
F(z0, pos(s(s(z1))), pos(z2)) → COND_F(greater_int(z0, pos(s(s(plus_nat(z1, z2))))), z0, pos(s(s(z1))), pos(z2))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
F(z0, pos(s(s(z1))), pos(s(z2))) → COND_F(greater_int(z0, pos(s(s(plus_nat(z1, s(z2)))))), z0, pos(s(s(z1))), pos(s(z2)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ QDP
COND_F(true, z0, pos(s(z1)), pos(z2)) → F(z0, pos(s(z1)), pos(s(z2)))
COND_F(true, z0, pos(z1), pos(s(z2))) → F(z0, pos(z1), pos(s(s(z2))))
F(z0, pos(z1), pos(s(s(z2)))) → COND_F1(greater_int(z0, pos(plus_nat(z1, s(s(z2))))), z0, pos(z1), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(z2)) → COND_F1(greater_int(z0, pos(s(plus_nat(z1, z2)))), z0, pos(s(z1)), pos(z2))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F1(greater_int(z0, pos(s(plus_nat(z1, s(z2))))), z0, pos(s(z1)), pos(s(z2)))
COND_F1(true, z0, pos(s(z1)), pos(s(z2))) → F(z0, pos(s(s(z1))), pos(s(z2)))
COND_F1(true, z0, pos(z1), pos(s(s(z2)))) → F(z0, pos(s(z1)), pos(s(s(z2))))
COND_F1(true, z0, pos(s(z1)), pos(z2)) → F(z0, pos(s(s(z1))), pos(z2))
F(z0, pos(z1), pos(s(s(z2)))) → COND_F(greater_int(z0, pos(plus_nat(z1, s(s(z2))))), z0, pos(z1), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(s(s(z2)))) → COND_F(greater_int(z0, pos(s(plus_nat(z1, s(s(z2)))))), z0, pos(s(z1)), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F(greater_int(z0, pos(s(plus_nat(z1, s(z2))))), z0, pos(s(z1)), pos(s(z2)))
F(z0, pos(s(s(z1))), pos(s(z2))) → COND_F(greater_int(z0, pos(s(s(plus_nat(z1, s(z2)))))), z0, pos(s(s(z1))), pos(s(z2)))
F(z0, pos(s(s(z1))), pos(z2)) → COND_F(greater_int(z0, pos(s(s(plus_nat(z1, z2))))), z0, pos(s(s(z1))), pos(z2))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
F(z0, pos(s(s(z1))), pos(z2)) → COND_F1(greater_int(z0, pos(s(plus_nat(s(z1), z2)))), z0, pos(s(s(z1))), pos(z2))
F(z0, pos(s(x1)), pos(s(s(z2)))) → COND_F1(greater_int(z0, pos(s(plus_nat(x1, s(s(z2)))))), z0, pos(s(x1)), pos(s(s(z2))))
F(z0, pos(s(s(z1))), pos(s(z2))) → COND_F1(greater_int(z0, pos(s(plus_nat(s(z1), s(z2))))), z0, pos(s(s(z1))), pos(s(z2)))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F1(greater_int(z0, pos(s(plus_nat(z1, s(z2))))), z0, pos(s(z1)), pos(s(z2)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ QDP
COND_F(true, z0, pos(s(z1)), pos(z2)) → F(z0, pos(s(z1)), pos(s(z2)))
COND_F(true, z0, pos(z1), pos(s(z2))) → F(z0, pos(z1), pos(s(s(z2))))
F(z0, pos(z1), pos(s(s(z2)))) → COND_F1(greater_int(z0, pos(plus_nat(z1, s(s(z2))))), z0, pos(z1), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F1(greater_int(z0, pos(s(plus_nat(z1, s(z2))))), z0, pos(s(z1)), pos(s(z2)))
COND_F1(true, z0, pos(s(z1)), pos(s(z2))) → F(z0, pos(s(s(z1))), pos(s(z2)))
COND_F1(true, z0, pos(z1), pos(s(s(z2)))) → F(z0, pos(s(z1)), pos(s(s(z2))))
COND_F1(true, z0, pos(s(z1)), pos(z2)) → F(z0, pos(s(s(z1))), pos(z2))
F(z0, pos(z1), pos(s(s(z2)))) → COND_F(greater_int(z0, pos(plus_nat(z1, s(s(z2))))), z0, pos(z1), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(s(s(z2)))) → COND_F(greater_int(z0, pos(s(plus_nat(z1, s(s(z2)))))), z0, pos(s(z1)), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F(greater_int(z0, pos(s(plus_nat(z1, s(z2))))), z0, pos(s(z1)), pos(s(z2)))
F(z0, pos(s(s(z1))), pos(s(z2))) → COND_F(greater_int(z0, pos(s(s(plus_nat(z1, s(z2)))))), z0, pos(s(s(z1))), pos(s(z2)))
F(z0, pos(s(s(z1))), pos(z2)) → COND_F(greater_int(z0, pos(s(s(plus_nat(z1, z2))))), z0, pos(s(s(z1))), pos(z2))
F(z0, pos(s(s(z1))), pos(z2)) → COND_F1(greater_int(z0, pos(s(plus_nat(s(z1), z2)))), z0, pos(s(s(z1))), pos(z2))
F(z0, pos(s(x1)), pos(s(s(z2)))) → COND_F1(greater_int(z0, pos(s(plus_nat(x1, s(s(z2)))))), z0, pos(s(x1)), pos(s(s(z2))))
F(z0, pos(s(s(z1))), pos(s(z2))) → COND_F1(greater_int(z0, pos(s(plus_nat(s(z1), s(z2))))), z0, pos(s(s(z1))), pos(s(z2)))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
F(z0, pos(s(s(z1))), pos(z2)) → COND_F1(greater_int(z0, pos(s(s(plus_nat(z1, z2))))), z0, pos(s(s(z1))), pos(z2))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ QDP
COND_F(true, z0, pos(s(z1)), pos(z2)) → F(z0, pos(s(z1)), pos(s(z2)))
COND_F(true, z0, pos(z1), pos(s(z2))) → F(z0, pos(z1), pos(s(s(z2))))
F(z0, pos(z1), pos(s(s(z2)))) → COND_F1(greater_int(z0, pos(plus_nat(z1, s(s(z2))))), z0, pos(z1), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F1(greater_int(z0, pos(s(plus_nat(z1, s(z2))))), z0, pos(s(z1)), pos(s(z2)))
COND_F1(true, z0, pos(s(z1)), pos(s(z2))) → F(z0, pos(s(s(z1))), pos(s(z2)))
COND_F1(true, z0, pos(z1), pos(s(s(z2)))) → F(z0, pos(s(z1)), pos(s(s(z2))))
COND_F1(true, z0, pos(s(z1)), pos(z2)) → F(z0, pos(s(s(z1))), pos(z2))
F(z0, pos(z1), pos(s(s(z2)))) → COND_F(greater_int(z0, pos(plus_nat(z1, s(s(z2))))), z0, pos(z1), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(s(s(z2)))) → COND_F(greater_int(z0, pos(s(plus_nat(z1, s(s(z2)))))), z0, pos(s(z1)), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F(greater_int(z0, pos(s(plus_nat(z1, s(z2))))), z0, pos(s(z1)), pos(s(z2)))
F(z0, pos(s(s(z1))), pos(s(z2))) → COND_F(greater_int(z0, pos(s(s(plus_nat(z1, s(z2)))))), z0, pos(s(s(z1))), pos(s(z2)))
F(z0, pos(s(s(z1))), pos(z2)) → COND_F(greater_int(z0, pos(s(s(plus_nat(z1, z2))))), z0, pos(s(s(z1))), pos(z2))
F(z0, pos(s(x1)), pos(s(s(z2)))) → COND_F1(greater_int(z0, pos(s(plus_nat(x1, s(s(z2)))))), z0, pos(s(x1)), pos(s(s(z2))))
F(z0, pos(s(s(z1))), pos(s(z2))) → COND_F1(greater_int(z0, pos(s(plus_nat(s(z1), s(z2))))), z0, pos(s(s(z1))), pos(s(z2)))
F(z0, pos(s(s(z1))), pos(z2)) → COND_F1(greater_int(z0, pos(s(s(plus_nat(z1, z2))))), z0, pos(s(s(z1))), pos(z2))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
F(z0, pos(s(s(z1))), pos(s(z2))) → COND_F1(greater_int(z0, pos(s(s(plus_nat(z1, s(z2)))))), z0, pos(s(s(z1))), pos(s(z2)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ QDP
↳ QDP
COND_F(true, z0, pos(s(z1)), pos(z2)) → F(z0, pos(s(z1)), pos(s(z2)))
COND_F(true, z0, pos(z1), pos(s(z2))) → F(z0, pos(z1), pos(s(s(z2))))
F(z0, pos(z1), pos(s(s(z2)))) → COND_F1(greater_int(z0, pos(plus_nat(z1, s(s(z2))))), z0, pos(z1), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F1(greater_int(z0, pos(s(plus_nat(z1, s(z2))))), z0, pos(s(z1)), pos(s(z2)))
COND_F1(true, z0, pos(s(z1)), pos(s(z2))) → F(z0, pos(s(s(z1))), pos(s(z2)))
COND_F1(true, z0, pos(z1), pos(s(s(z2)))) → F(z0, pos(s(z1)), pos(s(s(z2))))
COND_F1(true, z0, pos(s(z1)), pos(z2)) → F(z0, pos(s(s(z1))), pos(z2))
F(z0, pos(z1), pos(s(s(z2)))) → COND_F(greater_int(z0, pos(plus_nat(z1, s(s(z2))))), z0, pos(z1), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(s(s(z2)))) → COND_F(greater_int(z0, pos(s(plus_nat(z1, s(s(z2)))))), z0, pos(s(z1)), pos(s(s(z2))))
F(z0, pos(s(z1)), pos(s(z2))) → COND_F(greater_int(z0, pos(s(plus_nat(z1, s(z2))))), z0, pos(s(z1)), pos(s(z2)))
F(z0, pos(s(s(z1))), pos(s(z2))) → COND_F(greater_int(z0, pos(s(s(plus_nat(z1, s(z2)))))), z0, pos(s(s(z1))), pos(s(z2)))
F(z0, pos(s(s(z1))), pos(z2)) → COND_F(greater_int(z0, pos(s(s(plus_nat(z1, z2))))), z0, pos(s(s(z1))), pos(z2))
F(z0, pos(s(x1)), pos(s(s(z2)))) → COND_F1(greater_int(z0, pos(s(plus_nat(x1, s(s(z2)))))), z0, pos(s(x1)), pos(s(s(z2))))
F(z0, pos(s(s(z1))), pos(z2)) → COND_F1(greater_int(z0, pos(s(s(plus_nat(z1, z2))))), z0, pos(s(s(z1))), pos(z2))
F(z0, pos(s(s(z1))), pos(s(z2))) → COND_F1(greater_int(z0, pos(s(s(plus_nat(z1, s(z2)))))), z0, pos(s(s(z1))), pos(s(z2)))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
F(y0, pos(x0), neg(x1)) → COND_F(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
COND_F(true, z0, pos(z1), neg(z2)) → F(z0, pos(z1), minus_nat(s(0), z2))
F(y0, pos(x0), neg(x1)) → COND_F1(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
COND_F1(true, z0, pos(z1), neg(z2)) → F(z0, pos(s(z1)), neg(z2))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
F(y0, pos(x0), neg(x1)) → COND_F(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
COND_F(true, z0, pos(z1), neg(z2)) → F(z0, pos(z1), minus_nat(s(0), z2))
F(y0, pos(x0), neg(x1)) → COND_F1(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
COND_F1(true, z0, pos(z1), neg(z2)) → F(z0, pos(s(z1)), neg(z2))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
plus_nat(0, x0)
plus_nat(s(x0), x1)
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ QDP
F(y0, pos(x0), neg(x1)) → COND_F(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
COND_F(true, z0, pos(z1), neg(z2)) → F(z0, pos(z1), minus_nat(s(0), z2))
F(y0, pos(x0), neg(x1)) → COND_F1(greater_int(y0, minus_nat(x0, x1)), y0, pos(x0), neg(x1))
COND_F1(true, z0, pos(z1), neg(z2)) → F(z0, pos(s(z1)), neg(z2))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ Instantiation
COND_F(true, z0, neg(z1), neg(z2)) → F(z0, neg(z1), minus_nat(s(0), z2))
F(y0, neg(x0), neg(x1)) → COND_F(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
F(y0, neg(x0), pos(x1)) → COND_F(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
COND_F(true, z0, neg(z1), pos(z2)) → F(z0, neg(z1), pos(s(z2)))
F(y0, neg(x0), pos(x1)) → COND_F1(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
COND_F1(true, y0, neg(x1), y2) → F(y0, minus_nat(s(0), x1), y2)
F(y0, neg(x0), neg(x1)) → COND_F1(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
COND_F1(true, z0, neg(z1), pos(z2)) → F(z0, minus_nat(s(0), z1), pos(z2))
COND_F1(true, z0, neg(z1), neg(z2)) → F(z0, minus_nat(s(0), z1), neg(z2))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
COND_F(true, z0, neg(z1), neg(z2)) → F(z0, neg(z1), minus_nat(s(0), z2))
F(y0, neg(x0), neg(x1)) → COND_F(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
F(y0, neg(x0), pos(x1)) → COND_F(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
COND_F(true, z0, neg(z1), pos(z2)) → F(z0, neg(z1), pos(s(z2)))
F(y0, neg(x0), pos(x1)) → COND_F1(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, neg(x0), neg(x1)) → COND_F1(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
COND_F1(true, z0, neg(z1), pos(z2)) → F(z0, minus_nat(s(0), z1), pos(z2))
COND_F1(true, z0, neg(z1), neg(z2)) → F(z0, minus_nat(s(0), z1), neg(z2))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
COND_F(true, z0, neg(z1), pos(z2)) → F(z0, neg(z1), pos(s(z2)))
F(y0, neg(x0), pos(x1)) → COND_F(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, neg(x0), pos(x1)) → COND_F1(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
COND_F1(true, z0, neg(z1), pos(z2)) → F(z0, minus_nat(s(0), z1), pos(z2))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
COND_F(true, z0, neg(z1), pos(z2)) → F(z0, neg(z1), pos(s(z2)))
F(y0, neg(x0), pos(x1)) → COND_F(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, neg(x0), pos(x1)) → COND_F1(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
COND_F1(true, z0, neg(z1), pos(z2)) → F(z0, minus_nat(s(0), z1), pos(z2))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
plus_nat(0, x0)
plus_nat(s(x0), x1)
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ QDP
COND_F(true, z0, neg(z1), pos(z2)) → F(z0, neg(z1), pos(s(z2)))
F(y0, neg(x0), pos(x1)) → COND_F(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
F(y0, neg(x0), pos(x1)) → COND_F1(greater_int(y0, minus_nat(x1, x0)), y0, neg(x0), pos(x1))
COND_F1(true, z0, neg(z1), pos(z2)) → F(z0, minus_nat(s(0), z1), pos(z2))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ UsableRulesProof
F(y0, neg(x0), neg(x1)) → COND_F(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
COND_F(true, z0, neg(z1), neg(z2)) → F(z0, neg(z1), minus_nat(s(0), z2))
F(y0, neg(x0), neg(x1)) → COND_F1(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
COND_F1(true, z0, neg(z1), neg(z2)) → F(z0, minus_nat(s(0), z1), neg(z2))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), pos(0)) → false
greater_int(neg(0), pos(0)) → false
greater_int(pos(0), pos(s(y))) → false
greater_int(neg(0), pos(s(y))) → false
greater_int(pos(s(x)), pos(0)) → true
greater_int(neg(s(x)), pos(0)) → false
greater_int(neg(s(x)), pos(s(y))) → false
greater_int(pos(s(x)), pos(s(y))) → greater_int(pos(x), pos(y))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))
↳ ITRS
↳ ITRStoQTRSProof
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ RemovalProof
↳ RemovalProof
↳ Narrowing
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ Narrowing
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Narrowing
↳ QDP
↳ UsableRulesProof
↳ QDP
↳ QReductionProof
↳ QDP
↳ Rewriting
↳ QDP
↳ Rewriting
↳ QDP
↳ Instantiation
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ Instantiation
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ UsableRulesProof
↳ QDP
F(y0, neg(x0), neg(x1)) → COND_F(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
COND_F(true, z0, neg(z1), neg(z2)) → F(z0, neg(z1), minus_nat(s(0), z2))
F(y0, neg(x0), neg(x1)) → COND_F1(greater_int(y0, neg(plus_nat(x0, x1))), y0, neg(x0), neg(x1))
COND_F1(true, z0, neg(z1), neg(z2)) → F(z0, minus_nat(s(0), z1), neg(z2))
minus_nat(s(x), 0) → pos(s(x))
minus_nat(s(x), s(y)) → minus_nat(x, y)
minus_nat(0, 0) → pos(0)
minus_nat(0, s(y)) → neg(s(y))
plus_nat(0, x) → x
plus_nat(s(x), y) → s(plus_nat(x, y))
greater_int(pos(0), neg(0)) → false
greater_int(neg(0), neg(0)) → false
greater_int(pos(0), neg(s(y))) → true
greater_int(neg(0), neg(s(y))) → true
greater_int(pos(s(x)), neg(0)) → true
greater_int(neg(s(x)), neg(0)) → false
greater_int(pos(s(x)), neg(s(y))) → true
greater_int(neg(s(x)), neg(s(y))) → greater_int(neg(x), neg(y))
plus_nat(0, x0)
plus_nat(s(x0), x1)
minus_nat(0, 0)
minus_nat(0, s(x0))
minus_nat(s(x0), 0)
minus_nat(s(x0), s(x1))
greater_int(pos(0), pos(0))
greater_int(pos(0), neg(0))
greater_int(neg(0), pos(0))
greater_int(neg(0), neg(0))
greater_int(pos(0), pos(s(x0)))
greater_int(neg(0), pos(s(x0)))
greater_int(pos(0), neg(s(x0)))
greater_int(neg(0), neg(s(x0)))
greater_int(pos(s(x0)), pos(0))
greater_int(neg(s(x0)), pos(0))
greater_int(pos(s(x0)), neg(0))
greater_int(neg(s(x0)), neg(0))
greater_int(pos(s(x0)), neg(s(x1)))
greater_int(neg(s(x0)), pos(s(x1)))
greater_int(pos(s(x0)), pos(s(x1)))
greater_int(neg(s(x0)), neg(s(x1)))